<template>
    <div>
        <el-card class="!border-none" shadow="never">
            <el-alert type="warning" title="温馨提示：用于管理网站的分类，只可添加到一级" :closable="false" show-icon />
        </el-card>
        <el-card class="!border-none mt-4" shadow="never" v-loading="pager.loading">
            <div>
                <el-button class="mb-4" v-perms="['article.articleCate/add']" type="primary" @click="handleAdd()">
                    <template #icon>
                        <icon name="el-icon-Plus" />
                    </template>
                    新增
                </el-button>
            </div>
            <el-table size="large" :data="pager.lists">
                <el-table-column label="栏目名称" prop="name" min-width="120" />
                <el-table-column label="文章数" prop="article_count" min-width="120" />
                <el-table-column label="状态" min-width="120">
                    <template #default="{ row }">
                        <el-switch
                            v-perms="['article.articleCate/updateStatus']"
                            v-model="row.is_show"
                            :active-value="1"
                            :inactive-value="0"
                            @change="changeStatus($event, row.id)"
                        />
                    </template>
                </el-table-column>
                <el-table-column label="排序" prop="sort" min-width="120" />
                <el-table-column label="操作" width="120" fixed="right">
                    <template #default="{ row }">
                        <el-button v-perms="['article.articleCate/edit']" type="primary" link @click="handleEdit(row)"> 编辑 </el-button>
                        <el-button v-perms="['article.articleCate/delete']" type="danger" link @click="handleDelete(row.id)"> 删除 </el-button>
                    </template>
                </el-table-column>
            </el-table>
            <div class="flex justify-end mt-4">
                <pagination v-model="pager" @change="getLists" />
            </div>
        </el-card>
        <edit-popup v-if="showEdit" ref="editRef" @success="getLists" @close="showEdit = false" />
    </div>
</template>
<script lang="ts" setup name="articleColumn">
import { articleCateDelete, articleCateLists, articleCateStatus } from "@/api/article"
import { usePaging } from "@/hooks/usePaging"
import feedback from "@/utils/feedback"
import EditPopup from "./edit.vue"
const editRef = shallowRef<InstanceType<typeof EditPopup>>()
const showEdit = ref(false)

const { pager, getLists } = usePaging({
    fetchFun: articleCateLists
})
const handleAdd = async () => {
    showEdit.value = true
    await nextTick()
    editRef.value?.open("add")
}

const handleEdit = async (data: any) => {
    showEdit.value = true
    await nextTick()
    editRef.value?.open("edit")
    editRef.value?.getDetail(data)
}

const handleDelete = async (id: number) => {
    await feedback.confirm("确定要删除？")
    await articleCateDelete({ id })
    getLists()
}

const changeStatus = async (is_show: any, id: number) => {
    try {
        await articleCateStatus({ id, is_show })
        getLists()
    } catch (error) {
        getLists()
    }
}

getLists()
</script>
